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<Entity A> 

<Entity B> 

<Entity C> Data </Entity C> 

<Entity D> Data </Entity D> 
</Entity B> 
<Entity E> 

<Entity F> Data </Entity F> 
</Entity E> 
<Entity G> 

<Entity F> Data </Entity F> 
</Entity G> 
<Entity H> 

<Entity I> Data </Entity I> 
</Entity H> 
<Entity H> 

<Entity I> Data </Entity I> 
</Entity H> 
</Entity A> 
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<directory>(100) 
<person> (102) 

<name> (104) 

<first> John </first> (107, 124) 
<last> Public </last> (108, 126) 
</name>(128) 
<home> (105) 

<address>(110) 

<line 1> 123 Main St </linel> (1 12,130) 
<city> Anyville </city>(l 14, 132) 
<state> WA </state> (1 16,134) 
<zip> 98198 </zip>(l 18,136) 
</address>(138) 

<phone> 206-255-1234 </phone> (120, 140) 
</home> (142) 
<work>(106) 

<phone> 206-555-578 </phone> (122, 144) 
</work> (146) 
<person> (148) 
</directory>(150) 



Fig. 6 A 
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502 

<xsl:stylsheet xmins:xsl=http://www.w3.org/XSL/Transform/l .0> 

<xsl:template match:7 H > 
<result> 

<xsl: apply-templates 

select="companyrecords/employees/employee"/> 

</result> 
</xsl:template> 



<xsl:template match: "employee M > 

<xsl:variable name- 'depid" select=department/@idref7> 
<person> 

<xsl: apply-templates select- f name f 7> 
<number><xsl:value-of select= ,, phone ,t /></number> 
<depname> 

<xsl: apply-templates 

select="//department[@id=$depid]/name ,, /> 

</depname> 
</person> 
</xsl:template> 



<xsl:template match: M employee/name"> 
<xsl:value-of select= H first" l> 
<xsl: text> </xsl:text> 
<xsl:value-of select= :M last' , /> 

</xsl:template> 

<xsl:template match: "department/name M > 

<xsl:value-of select= n ." /> 
</xsl:template> 

</xsl:stylesheet> 



Fig. 12A 
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<companyrecords> 
<employees> 

<employee> 

<namexfirst>fhame</first><last>lname</last></name> 
<ssn>ssn</ssn> 
<department idref=deptid/> 
<phone>xxx-xxxx</phone> 
</employee> 
</employees> 
<departments> 

<department id=deptid> 

<name> dept name </name> 
</department> 
</departments> 
</companyrecords> 
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(QueryLoop "Select" 
From 

Where 



name.first, name.last, employee.phone, name2.pcdata, 
companyrecords, multiemployee, 
Employee, name, companyrecords as cr2, 
companyrecords. employees = multiemployee. id AND 
cr2.departments = multidepartment.id AND 
multidepartment. department = department, id AND 
department.id = employ ee.idref, 
department, name = name2.id) 



(CreateElement "result") 

(Group "") // empty group operation groups all inside Vesult" 
(CreateElement "person") 

(CreateText"$QL.l SQL.2") 
(CreateElement "phone" body="$QL.3") 
(CreateElement "depname" body="$QL.4") 



Fig. 12C 
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